#include "gdkeventtranslator.h"
#include "gdkframeclockprivate.h"
#include "gdkinternals.h"
-#include "gdkscreen.h"
#include "gdkinternals.h"
#include "gdkdeviceprivate.h"
#include "gdkkeysprivate.h"
{
GdkToplevelX11 *toplevel = _gdk_x11_window_get_toplevel (window);
GdkDisplay *display = GDK_WINDOW_DISPLAY (window);
- GdkScreen *screen = GDK_WINDOW_SCREEN (window);
+ GdkX11Screen *screen = GDK_WINDOW_SCREEN (window);
Atom type;
gint format;
GdkWindow *window;
gboolean is_substructure;
GdkWindowImplX11 *window_impl = NULL;
- GdkScreen *screen = NULL;
GdkX11Screen *x11_screen = NULL;
GdkToplevelX11 *toplevel = NULL;
GdkX11Display *display_x11 = GDK_X11_DISPLAY (display);
if (!GDK_IS_WINDOW (window))
return FALSE;
- screen = GDK_WINDOW_SCREEN (window);
- x11_screen = GDK_X11_SCREEN (screen);
+ x11_screen = GDK_WINDOW_SCREEN (window);
toplevel = _gdk_x11_window_get_toplevel (window);
window_impl = GDK_WINDOW_IMPL_X11 (window->impl);
if (xevent->type == DestroyNotify && !is_substructure)
{
- screen = GDK_X11_DISPLAY (display)->screen;
- x11_screen = GDK_X11_SCREEN (screen);
+ x11_screen = GDK_X11_DISPLAY (display)->screen;
if (x11_screen->wmspec_check_window == xevent->xdestroywindow.window)
{
x11_screen->window_manager_name = g_strdup ("unknown");
/* careful, reentrancy */
- _gdk_x11_screen_window_manager_changed (screen);
+ _gdk_x11_screen_window_manager_changed (x11_screen);
return_val = FALSE;
goto done;
* interpret UnmapNotify events as implying iconic state.
* http://bugzilla.gnome.org/show_bug.cgi?id=590726.
*/
- if (screen &&
- !gdk_x11_screen_supports_net_wm_hint (screen,
+ if (x11_screen &&
+ !gdk_x11_screen_supports_net_wm_hint (x11_screen,
gdk_atom_intern_static_string ("_NET_WM_STATE_HIDDEN")))
{
/* If we are shown (not withdrawn) and get an unmap, it means we were
: ""));
if (_gdk_x11_display_is_root_window (display, xevent->xconfigure.window))
{
- _gdk_x11_screen_size_changed (screen, xevent);
+ _gdk_x11_screen_size_changed (x11_screen, xevent);
}
#ifdef HAVE_XSYNC
if (xevent->type - display_x11->xrandr_event_base == RRScreenChangeNotify ||
xevent->type - display_x11->xrandr_event_base == RRNotify)
{
- if (screen)
- _gdk_x11_screen_size_changed (screen, xevent);
+ if (x11_screen)
+ _gdk_x11_screen_size_changed (x11_screen, xevent);
}
else
#endif
* Returns: (transfer none): the #GdkScreen corresponding to
* @xrootwin, or %NULL.
**/
-GdkScreen *
+GdkX11Screen *
_gdk_x11_display_screen_for_xrootwin (GdkDisplay *display,
Window xrootwin)
{
- GdkScreen *screen;
+ GdkX11Screen *screen;
XWindowAttributes attrs;
gboolean result;
GdkX11Display *display_x11;
g_slist_free (displays);
}
-GdkScreen *
+GdkX11Screen *
gdk_x11_display_get_screen (GdkDisplay *display)
{
return GDK_X11_DISPLAY (display)->screen;
#include <X11/extensions/Xfixes.h>
#endif
-static void gdk_x11_screen_dispose (GObject *object);
-static void gdk_x11_screen_finalize (GObject *object);
-static void init_randr_support (GdkScreen *screen);
+static void gdk_x11_screen_dispose (GObject *object);
+static void gdk_x11_screen_finalize (GObject *object);
+static void init_randr_support (GdkX11Screen *screen);
enum
{
* Since: 2.14
*/
XID
-gdk_x11_screen_get_monitor_output (GdkScreen *screen,
- gint monitor_num)
+gdk_x11_screen_get_monitor_output (GdkX11Screen *x11_screen,
+ gint monitor_num)
{
- GdkX11Screen *x11_screen = GDK_X11_SCREEN (screen);
GdkX11Display *x11_display = GDK_X11_DISPLAY (x11_screen->display);
GdkX11Monitor *monitor;
- g_return_val_if_fail (GDK_IS_SCREEN (screen), None);
g_return_val_if_fail (monitor_num >= 0, None);
g_return_val_if_fail (monitor_num < x11_display->monitors->len, None);
}
static int
-get_current_desktop (GdkScreen *screen)
+get_current_desktop (GdkX11Screen *screen)
{
Display *display;
Window win;
}
void
-gdk_x11_screen_get_work_area (GdkScreen *screen,
+gdk_x11_screen_get_work_area (GdkX11Screen *x11_screen,
GdkRectangle *area)
{
- GdkX11Screen *x11_screen = GDK_X11_SCREEN (screen);
Atom workarea;
Atom type;
Window win;
int desktop;
Display *display;
- display = GDK_SCREEN_XDISPLAY (screen);
+ display = GDK_SCREEN_XDISPLAY (x11_screen);
workarea = XInternAtom (display, "_NET_WORKAREA", True);
/* Defaults in case of error */
area->width = WidthOfScreen (x11_screen->xscreen);
area->height = HeightOfScreen (x11_screen->xscreen);
- if (!gdk_x11_screen_supports_net_wm_hint (screen,
+ if (!gdk_x11_screen_supports_net_wm_hint (x11_screen,
gdk_atom_intern_static_string ("_NET_WORKAREA")))
return;
if (workarea == None)
return;
- win = XRootWindow (display, gdk_x11_screen_get_screen_number (screen));
+ win = XRootWindow (display, gdk_x11_screen_get_screen_number (x11_screen));
result = XGetWindowProperty (display,
win,
workarea,
num % 4 != 0)
goto out;
- desktop = get_current_desktop (screen);
+ desktop = get_current_desktop (x11_screen);
if (desktop + 1 > num / 4) /* fvwm gets this wrong */
goto out;
* Since: 2.2
*/
Screen *
-gdk_x11_screen_get_xscreen (GdkScreen *screen)
+gdk_x11_screen_get_xscreen (GdkX11Screen *screen)
{
- return GDK_X11_SCREEN (screen)->xscreen;
+ return screen->xscreen;
}
/**
* Since: 2.2
*/
int
-gdk_x11_screen_get_screen_number (GdkScreen *screen)
+gdk_x11_screen_get_screen_number (GdkX11Screen *screen)
{
- return GDK_X11_SCREEN (screen)->screen_num;
+ return screen->screen_num;
}
static GdkX11Monitor *
}
static gboolean
-init_randr15 (GdkScreen *screen, gboolean *changed)
+init_randr15 (GdkX11Screen *x11_screen, gboolean *changed)
{
#ifdef HAVE_RANDR15
- GdkDisplay *display = GDK_SCREEN_DISPLAY (screen);
+ GdkDisplay *display = GDK_SCREEN_DISPLAY (x11_screen);
GdkX11Display *x11_display = GDK_X11_DISPLAY (display);
- GdkX11Screen *x11_screen = GDK_X11_SCREEN (screen);
XRRScreenResources *resources;
RROutput primary_output = None;
RROutput first_output = None;
}
static gboolean
-init_randr13 (GdkScreen *screen, gboolean *changed)
+init_randr13 (GdkX11Screen *x11_screen, gboolean *changed)
{
#ifdef HAVE_RANDR
- GdkDisplay *display = GDK_SCREEN_DISPLAY (screen);
+ GdkDisplay *display = GDK_SCREEN_DISPLAY (x11_screen);
GdkX11Display *x11_display = GDK_X11_DISPLAY (display);
- GdkX11Screen *x11_screen = GDK_X11_SCREEN (screen);
XRRScreenResources *resources;
RROutput primary_output = None;
RROutput first_output = None;
}
static void
-init_no_multihead (GdkScreen *screen, gboolean *changed)
+init_no_multihead (GdkX11Screen *x11_screen, gboolean *changed)
{
- GdkX11Screen *x11_screen = GDK_X11_SCREEN (screen);
GdkX11Display *x11_display = GDK_X11_DISPLAY (x11_screen->display);
GdkX11Monitor *monitor;
GdkRectangle geometry;
}
static gboolean
-init_multihead (GdkScreen *screen)
+init_multihead (GdkX11Screen *screen)
{
gboolean any_changed = FALSE;
return any_changed;
}
-GdkScreen *
+GdkX11Screen *
_gdk_x11_screen_new (GdkDisplay *display,
gint screen_number,
gboolean setup_display)
{
- GdkScreen *screen;
GdkX11Screen *x11_screen;
GdkX11Display *display_x11 = GDK_X11_DISPLAY (display);
const char *scale_str;
- screen = g_object_new (GDK_TYPE_X11_SCREEN, NULL);
+ x11_screen = g_object_new (GDK_TYPE_X11_SCREEN, NULL);
- x11_screen = GDK_X11_SCREEN (screen);
x11_screen->display = display;
x11_screen->xdisplay = display_x11->xdisplay;
x11_screen->xscreen = ScreenOfDisplay (display_x11->xdisplay, screen_number);
else
x11_screen->window_scale = 1;
- init_randr_support (screen);
- init_multihead (screen);
+ init_randr_support (x11_screen);
+ init_multihead (x11_screen);
- _gdk_x11_screen_init_visuals (screen, setup_display);
+ _gdk_x11_screen_init_visuals (x11_screen, setup_display);
- return screen;
+ return x11_screen;
}
void
}
static void
-init_randr_support (GdkScreen *screen)
+init_randr_support (GdkX11Screen *x11_screen)
{
- GdkX11Screen *x11_screen = GDK_X11_SCREEN (screen);
-
/* NB: This is also needed for XSettings, so don't remove. */
- XSelectInput (GDK_SCREEN_XDISPLAY (screen),
+ XSelectInput (GDK_SCREEN_XDISPLAY (x11_screen),
x11_screen->xroot_window,
StructureNotifyMask);
#ifdef HAVE_RANDR
- if (!GDK_X11_DISPLAY (GDK_SCREEN_DISPLAY (screen))->have_randr12)
+ if (!GDK_X11_DISPLAY (GDK_SCREEN_DISPLAY (x11_screen))->have_randr12)
return;
- XRRSelectInput (GDK_SCREEN_XDISPLAY (screen),
+ XRRSelectInput (GDK_SCREEN_XDISPLAY (x11_screen),
x11_screen->xroot_window,
RRScreenChangeNotifyMask
| RRCrtcChangeNotifyMask
}
static void
-process_monitors_change (GdkScreen *screen)
+process_monitors_change (GdkX11Screen *screen)
{
init_multihead (screen);
}
void
-_gdk_x11_screen_size_changed (GdkScreen *screen,
- XEvent *event)
+_gdk_x11_screen_size_changed (GdkX11Screen *screen,
+ XEvent *event)
{
#ifdef HAVE_RANDR
GdkX11Display *display_x11;
}
void
-_gdk_x11_screen_get_edge_monitors (GdkScreen *screen,
+_gdk_x11_screen_get_edge_monitors (GdkX11Screen *x11_screen,
gint *top,
gint *bottom,
gint *left,
gint *right)
{
#ifdef HAVE_XFREE_XINERAMA
- GdkX11Screen *x11_screen = GDK_X11_SCREEN (screen);
gint top_most_pos = HeightOfScreen (x11_screen->xscreen);
gint left_most_pos = WidthOfScreen (x11_screen->xscreen);
gint bottom_most_pos = 0;
}
void
-_gdk_x11_screen_window_manager_changed (GdkScreen *screen)
+_gdk_x11_screen_window_manager_changed (GdkX11Screen *screen)
{
g_signal_emit (screen, signals[WINDOW_MANAGER_CHANGED], 0);
}
gboolean
-gdk_x11_screen_get_setting (GdkScreen *screen,
+gdk_x11_screen_get_setting (GdkX11Screen *x11_screen,
const gchar *name,
GValue *value)
{
- GdkX11Screen *x11_screen = GDK_X11_SCREEN (screen);
const GValue *setting;
if (x11_screen->xsettings == NULL)
return TRUE;
out:
- return _gdk_x11_get_xft_setting (screen, name, value);
+ return _gdk_x11_screen_get_xft_setting (x11_screen, name, value);
}
static void
}
static void
-fetch_net_wm_check_window (GdkScreen *screen)
+fetch_net_wm_check_window (GdkX11Screen *x11_screen)
{
- GdkX11Screen *x11_screen;
GdkDisplay *display;
Window window;
GTimeVal tv;
gint error;
- x11_screen = GDK_X11_SCREEN (screen);
display = x11_screen->display;
g_return_if_fail (GDK_X11_DISPLAY (display)->trusted_client);
x11_screen->need_refetch_wm_name = TRUE;
/* Careful, reentrancy */
- _gdk_x11_screen_window_manager_changed (screen);
+ _gdk_x11_screen_window_manager_changed (x11_screen);
}
}
* Since: 2.2
**/
gboolean
-gdk_x11_screen_supports_net_wm_hint (GdkScreen *screen,
+gdk_x11_screen_supports_net_wm_hint (GdkX11Screen *x11_screen,
GdkAtom property)
{
gulong i;
- GdkX11Screen *x11_screen;
NetWmSupportedAtoms *supported_atoms;
GdkDisplay *display;
Atom atom;
- g_return_val_if_fail (GDK_IS_SCREEN (screen), FALSE);
-
- x11_screen = GDK_X11_SCREEN (screen);
display = x11_screen->display;
if (!G_LIKELY (GDK_X11_DISPLAY (display)->trusted_client))
return FALSE;
- supported_atoms = g_object_get_data (G_OBJECT (screen), "gdk-net-wm-supported-atoms");
+ supported_atoms = g_object_get_data (G_OBJECT (x11_screen), "gdk-net-wm-supported-atoms");
if (!supported_atoms)
{
supported_atoms = g_new0 (NetWmSupportedAtoms, 1);
- g_object_set_data_full (G_OBJECT (screen), "gdk-net-wm-supported-atoms", supported_atoms, cleanup_atoms);
+ g_object_set_data_full (G_OBJECT (x11_screen), "gdk-net-wm-supported-atoms", supported_atoms, cleanup_atoms);
}
- fetch_net_wm_check_window (screen);
+ fetch_net_wm_check_window (x11_screen);
if (x11_screen->wmspec_check_window == None)
return FALSE;
* Since: 2.2
**/
const char*
-gdk_x11_screen_get_window_manager_name (GdkScreen *screen)
+gdk_x11_screen_get_window_manager_name (GdkX11Screen *x11_screen)
{
- GdkX11Screen *x11_screen;
GdkDisplay *display;
- x11_screen = GDK_X11_SCREEN (screen);
display = x11_screen->display;
if (!G_LIKELY (GDK_X11_DISPLAY (display)->trusted_client))
return x11_screen->window_manager_name;
- fetch_net_wm_check_window (screen);
+ fetch_net_wm_check_window (x11_screen);
if (x11_screen->need_refetch_wm_name)
{
}
}
- return GDK_X11_SCREEN (screen)->window_manager_name;
+ return x11_screen->window_manager_name;
}
static void
}
static guint32
-get_netwm_cardinal_property (GdkScreen *screen,
- const gchar *name)
+get_netwm_cardinal_property (GdkX11Screen *x11_screen,
+ const gchar *name)
{
- GdkX11Screen *x11_screen = GDK_X11_SCREEN (screen);
GdkAtom atom;
guint32 prop = 0;
Atom type;
atom = gdk_atom_intern_static_string (name);
- if (!gdk_x11_screen_supports_net_wm_hint (screen, atom))
+ if (!gdk_x11_screen_supports_net_wm_hint (x11_screen, atom))
return 0;
XGetWindowProperty (x11_screen->xdisplay,
x11_screen->xroot_window,
- gdk_x11_get_xatom_by_name_for_display (GDK_SCREEN_DISPLAY (screen), name),
+ gdk_x11_get_xatom_by_name_for_display (GDK_SCREEN_DISPLAY (x11_screen), name),
0, G_MAXLONG,
False, XA_CARDINAL, &type, &format, &nitems,
&bytes_after, &data);
* Since: 3.10
*/
guint32
-gdk_x11_screen_get_number_of_desktops (GdkScreen *screen)
+gdk_x11_screen_get_number_of_desktops (GdkX11Screen *screen)
{
return get_netwm_cardinal_property (screen, "_NET_NUMBER_OF_DESKTOPS");
}
* Since: 3.10
*/
guint32
-gdk_x11_screen_get_current_desktop (GdkScreen *screen)
+gdk_x11_screen_get_current_desktop (GdkX11Screen *screen)
{
return get_netwm_cardinal_property (screen, "_NET_CURRENT_DESKTOP");
}